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(54) Method for coupling a wireless terminal to a data transmission network and a wireless 
termin&l 



(57) The invention relates to a terminal (A), which 
comprises at least one network interface card (N1C1 , 
NIC2, NIC3) for setting up a data transmission connec- 
tion to a communication network (NW1, NW2, NW3. 
MNW) for packet switched data transmission, and 
means (PD) for forming packets of the information to be 
transmitted and for unpacking information from the re- 
ceived packets. The terminal (A) is allocated at least one 
first address identifying the terminal (A), and at least one 
data network-specific second address. The means (PD) 
for forming packets comprise means for connecting the 



first address to the packets', and the terminal (A) also 
comprises a network interface selection driver (NISD), 
which contains means for selecting the communication 
network (NW1 , NW2, NW3, MNW) used in data trans- 
mission at a given time, means for transmitting packets 
between the means (PD) for forming packets and the 
network interface card (NIC1 , NIC2, NIC3) correspond- 
ing to the data transmission network (NW1 , NW2, NW3, 
MNW) used at a given time, and means for modifying 
the first address to the second address according to the 
data transmission network used in the packets at a given 
time. 
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Description 

[0001 ] The present invention relates to a wireless ter- 
minal according to tne preamble of the appended claim 
1 , and to a method according to the appended claim 8, 
for coupling a wireless terminal to a data transmission 
network. 

[0002] Considerable growth in the use of computers 
has increased the need for establishing data transmis- 
sion networks, to which these computers are coupled. 
Especially in office use, a local area network, such as 
the so-called Ethernet data network, is used as a data 
transmission network, to which office computers, print- 
ers and other corresponding devices are connected. 
Tnus, it is possible to use other resources connected to 
the local area network from the computer, for example 
for printing, wherein it is not necessary to provide each 
computer with' such peripheral devices. The computer 
connected to the local area network contains a network 
interface card, or the like, which comprises means nec- 
essary for establishing a data transmission connection 
between the computer and the local area network. Inter- 
office local area networks are typically implemented by 
means of a land! in e, for example by using a so-called 
thin Ethernet cabling. With the thin Ethernet cabling it is 
possible to achieve a speed of 10 Mb/s, but for er^arnple 
with twin cabling, it is possible 1 to use transmission 
speeds of even 100 Mb/s. 

[0003] ii is also possible to implement the local area 
network as a wireless local area network WLAN. These 
wireless local area networks are typically based on the 
use of radio moderns, wherein the office can be included 
in the range of the local area network with one or more 
such radio modems. The computer is equipped with a 
network interface card, which comprises, for instance, 
a radio transceiver for setting up a connection to a radio 
modem in the local area network. In such a wireless to- - 
cal area network, the placement of the computers is con- 
siderably freer compared to a fixed land! in e local area 
network. Such wireless local area networks intended for 
office use may have a relatively large bandwidth, where- 
in it is possible to achieve data transmission rates as 
high as 2 Mb/s. In particular, it is easy to connect port- 
able computers to such a wireless local area network. 
[0004] In addition to the above presented local area 
network solutions, the global Internet data network is 
known, which has recently grown very rapidly in popu- 
larity. The aforementioned local area networks can con- 
stitute a part of such Internet data network, wherein a 
data transmission connection to the Internet data net- 
work is set up from the locai area network LAN, WLAN. 
Such a data transmission connection can be, for exam- 
ple, a modern connection from the server computer of 
the local area network to the server computer ot Internet 
operator, or the server computer of the local area net- 
work can be coupled to form a part of the Internet data 
network. " * 

[0005] In connection with portable computers, so- 



2 

called PCMCIA cards have been developed, which con- 
tain buiil-in mobile station features, such as a GSM mo- 
bile station and peripheral circuits required for data 
transmission. Thus, it is possible to set up a data call 

5 from such a wireless data processor via the GSM mobile 
communication network to another data processor or 
even to a local area network of an office. Previously, a 
restriction in such data transmission utilizing the GSM 
mobile communication network has been the relatively 

10 low data transmission rate of 9600 bits/s, but solutions 
capable of faster data transmission are under develop- 
ment, such as HSCSD (High Speed Circuit Switched 
Data) and GPRS (General Packet Radio Service). The 
appended Fig; 1 presents in a reduced skeleton diagram 

is the aforementioned different network types. 

[0006] As portable computers are becoming smaller 
in sizecand thair features aro Increasing, it has become 
more and more popular to use. them also in offices. A 
• portable computer, provided with a network interface 

20 card intended for use in a wireless local area network, 
can be used as a wireless terminal in connection with 
the wireless local area network WLAN. The local area 
networ k of an office can consist of both a landline locai 
" area network. LAN and a wireless local area network 

25 WLAN. For example, upon enlargement of the office, a 
fixed interconnection is not necessarily made for the to- 
ca3 area network, but the extension of the local area net- 
work is implemented with such a wireless local area net- 
work solution in the office. Jn the office, the terminal 

3(* could thus primarily use the landline local area network, 
* wherein a network interface card for the landline local 
area network is connected to the portable computer. To 
mako better mobility possible, a network interface card 
for the wireless local area network is changed in the 

35 portable computer At this stage, however, the user of 
the terminal has to terminate the network connections 
in uso at that momant and change the network interface 
card, after which the connection to the local area net- 
v.oik can be set up again. In some situations, it might 
be necessary to use the terminal outside the office and 
be connected to the local area network of the office. 
Thus, when using methods and local area networks cur- 
> rently known, it is possible to change the network inter- 
face card in the portable computer whereby the connec- 

45 tion can be set up via a mobile communication network. 
Also in this situation it Is not possible to change the con- 
nection by using methods and terminals of prior art with- 
out terminating the active connections. 
[0007] Furthermore, a problem in the different com- 

so munication networks presented above is, for instance, 
that in each communication network, a different terminal 
identification is used. Differences in the terminal identi- 
fication used by different data transmission networks do 
not necessarily cause inconveniences for the user of the 

55 terminal, because s/he is always aware of which net- 

- . work s/he. is using. Nevertheless, when an attempt is 
made to set up a connection to this terminal, the person 
who sets up the connection to the terminal has to know 
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the location in the communication network to which the 
terminal in question is connected at a given time. One 
such connection set-up situation is when an attempt is 
made to set up a call via the Internet data network. An- 
other drawback is that the user of such different data 
transmission networks has to monitor the quality of the 
connection. For example, when the user moves inside 
the office and uses the wireless local area network 
WLAN, in some parts of the office the quality of the con- 
nection may become so poor that data transmission is 
disturbed or delayed significantly. Thus, the user should 
try to shift to 'such a data transmission network, in which, 
a better 5 connection quality is achieved, for example to 
a iandline local area network LAN, if such is in thevicin- . 
ity or to the GSM mobile communication network, if the 

- user is In its coverage: area; This change of the data. 

- transmission network causes the problems described 
above: termination' of the existing connections, -setting 

- up new connections and, if necessary, also cutting .^off 
or setting up a telephone connection* - o / 

* [0008] * It is a purpose of the present invention to pro- 
vide a method for coupling a portable terminal iry a flex- 
ible manner to a data transmission network; and for 
changing the data transmission connection used at a 
given time to anothetfdata transmission network when 
necessary, as well as to a portable terminal according 
to the method. A wireless terminal according to the, 

- present invention is characterized in what will be pre- 
sented in the characterizing part of the appended claim 

■ 1. A method according to the present invention is char- 
acterized in what will be presented in the characterizing 
part of the appended claim 8. The invention is based on 
the idea that the network layer address (IP address) of; 
the terminal and the; link layer addresses used by the 
different network interface solutions available in jhe ter- 
minal are combined in the terminal. 

[0009] With the present invention, significant advan- 
tages are achieved; cornpared.to methods and termi-, 
nals of prior art. The embodiment according to the in? 
vention makes it possible to supplement the operating 
system used in the terminal with the functionality of a 
mobile terminal, without a need to make changes in the 
operational modules of the operating system or in the 
network interface software. Thus, such a multi-mode 
terminal can be used in several local area networks of 
different types and in other communication .networks,, 
and even in such a way that the communication network 
used at a given time can be changed without terminating . 
active connections. This transition can be arranged to 
be conducted in such a way that the user does not even 
notice the transition. .Thus, it impossible to use one net- 
work layer address in the terminal, wherein it is not nec- 
essary for the applications used in the terminal to know 

■ which physical data transmission network is used at-a 
given time. This invention also makes it possible to use, 
of all the data transmission networks available at g time, 
the data transmission network, in which the best possi- 
ble connection quality is achieved. In addition, when the 



quality of the connection possibly becomes poor, the da- 
ta transmission network can be changed to another data 
transmission network, in which a better connection qual- 
ity is possibly achieved at that moment. Also, the user 

5 of the terminal according to the invention can be com- 
municated with, without the initiator of the communica- 
tion having to know to which data transmission network 
the terminal is coupled at a given time. 
[001 0] In the following, the invention will be described 

10 in more detail, by way of example only, with reference 
to the appended figures, in which 



Fig. 1 shows in a reduced skeleton diagram some 
network types, in which the invention can be 
advantageously applied, 

Fig.2 shows a terminal according to an advanta- 
geous embodiment of the invention in a re- 
duced block diagram, 

Fig. 3a shows the structure of an operating system 
in a reduced manner, 



15 



20 



Fig. 3b shows the network architecture of an oper- 
as , , ating : system in a reduced manner, 

. Fig, 3c^ .shows the network controller interface of the 
network architecture according to Fig. 3b in 
a reduced manner, 

Fig v 4 . shows the coupling of and data transmission 
... , . between two terminals in different functional 
. layers, 

35 Fig. 5 shows , an advantageous example of the 
, .« , message-structure of the address resolution 
. protocol ARP, 

Eifl. 6 •". shows the network architecture of a system, 
.4a , jn which it is advantageous to apply the in- 

dention,.. 

Fig, 7 ^ : shows the f unctionaiity of a terminal accord- 
. ,. / ing to an advantageous embodiment of the 
45 _ , , invention in a reduced manner, 



Fig. 8a ; . is an arrow diagram showing data transmis- 
. sion in a terminal according to an advanta- 
geous embodiment of the invention, 

Fig. 8b is an arrrow diagram showing data reception 
in a terminal according to an advantageous 
embodiment of the invention, and 

Fig. 8c is an arrow diagram showing the change of 
. a data transmission, network in a terminal ac- 
cording to an advantageous embodiment of 
the invention. 



so 
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[0011] In tha following, the invention will be described 
by using as an example of the mobile terminal a portable 
computer, which is presented in a reduced block dia- 
gram in Fig. 2. The operating system in the computer is 
the Windows® NT operating system developed by Mi- 
crosoft Corporation, but it is obvious that the invention 
can be applied also in connection with other operating 
systems. Furthermore, in a terminal A there are several 
network interface adapters NIC1, NIC2, NIC3 available 
for, coupling to data transmission networks of different 
types, of which an Ethernet type landline local area net- 
work, a wireless local area network WLAN according to 
the IEEE standard 802.11, and a GSM mobile commu- 
nication network are mentioned as examples, but also 
other data transmission solutions, such as the packet 
switched data transmission system GPRS (General 
Packet Radio Service) of the GSM system and LPRF 
(Low Power RF) based on a low power radio signalling, , 



can be.applied in connection with the present invention. 
Such terminal A is also called a multi-mode terminal. , 
[0012] The .appended Fig. 3a presents in a reduced 
manner the structure of the Windows NT operating sys? 
tern. .Tha lowermost level contains the actual hardware 

: partr which is.controlled by means of operating system 
functions and divers connected to the operating system. 

; Tho hardware. part includes, Jor instance,. a microproc- 
essor |iP, memory means MEM, a connectbn logic I/O, 
a display device D, and a keyboard K. For controlling 
toe drivers, the operating system contains an I/O man- 
ager,- which conducts, for instance, the start-up of the 
drivers and attends to the communication between the 
drivers and the rest of the operating system or other ap- 
plications. Particular operating system functions, and a 
large part o? the driver functions are conducted in a so- 
called kernel mode. Part of the operating system func- 
tions and the application programs started, by the user 
are set to operate in a so-called user mode. The appli- 
cations operating in this user mode have more restricted 
operating possibilities; for example, part of the memory 
space and processor instructions are available solely in 
the kernel mode, which is art known as such by anyone 
skilled in the art. Hereinbelow, for the purpose of under- 
standing the present invention, this description focuses 
primarily on the network interface architecture, i.e: the. 
function of the network interface card, network interface, 
drivers, operating system, network interface .functions 
and application programs. Fig. 3b presents as an exam- 
ple the network interface architecture of the Windows 
NT operating system in a reduced manner. 
[0013] The network interface architecture comprises 
a network interface card NIC,. by means of which the 
actual physical data transmission connection is estab- 
lished. The network interface card is, for example, an 
Ethernet. network. interface card or a PCMCIA type 
WLAN network interface card. The practical implemen- 
tation of this network interface card depends for in- 
stance, on the type of network interface in question. For 
example, a network interface card intended for a wire- 



less local area network comprises a radio modem, or 
the like, whereby it is possible to set up a wireless data 
transmission connection to the radio modem of the local 
area network. Correspondingly, when connecting to the 

5 GSM mobile communication network, the network inter- 
face card comprises either a data interface to the mobile 
, station (e.g. Nokia Cellular Data Suite), through which 
the data transmission connection is set up, or the net- 
work interface card can also comprise a mobile station 

10 transceiver for setting up a connection to the mobile 
communication network (e.g. . Nokia Cellular Card 
Phone). Thus, the network interface card constitutes 
said physical layer and can also contain features of the 
link layer. 

is [0014] . The network interface card driver NICD at- 
- tends, for instance, to controlling the network interface 
card N!C1 , NIC2, NIC3 and transmitting data between 
the network interface card NIC1, NIC2, NIC3 and the 
~~ protocol driver PD. The network interface card NIC1 , 
20 fs|l C2, N IC3, and th e network interface driver NICD con- 
stitute the layers of the lowermost level in the protocol 
stack. . .. . 

[0015] The network interface card driver NICD com- 
municates with the protocol driver PD. The protocol driv- 
es er PD implements, iri this advantageous embodiment, 
the network layer arid the transport layer of the protocol 
stack. The protocol driver PD uses services of the net- 
work interface card driver NICD in data transmission. 
The protocol driver PD, for instance, forms the informa- 
30 tion to be transmitted into packets which correspond to 
the link layer used at a given time, and are transmitted 
by the prptbcol driver PD to the network interface card 
driver NICD. . \ 

[0016] The upper level interface of the protocol driver 
35 PD forms a so-called transport driver interface TDI. This 
is provided with emulator applications (e.g. sockets em- 
ulator), or the like, whereby for instance a telecommu- 
nication application, such as a Windows browser pro- 
gram (WEB browser)', can communicate with the proto- 
40 col driver PD. 

[0017] For applying different data networks, network 
driver interface specifications NDIS are implemented in 
, the Windows NT operating system, for the purpose pro- 
1 vkJing the functional features common to the drivers of 
45 the data communication networks of different types. 
Thus, the hardware-specific and protocol-specific parts 
are. implemented in the lower level network drivers. Fig. 
3c presents an architecture according to such a network 
driver interface specification, which is located between 
so .the driver interface of the transport layer and the network 
interface card, and which is marked with NDIS in this 
description. This NDIS network interface architecture is 
advantageously, composed of three kinds of drivers: 
* NDIS protocol drivers, NDIS intermediate drivers and 
ss NDIS network interface card (NIC) drivers. The terminal 
contains typically a separate network interface card driv- 
er NICD for each network interface card, which commu- 
nicates with, the network interface card driver and the 
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upper level drivers, wherein it is not necessary for the 
upper level drivers to know which data transmission net- 
work the terminal A is connected to at a given time. 
Hereinbelow, a shorter term NIC driver will be used for 
these network interface card drivers D1, D2, D3 and s 
they will be marked with the references D1 , D2, 03. 
[001 8] In the Internet data network, a TCP/l P protocol 
stack is generally used, which can be divided into five 
functional layers. These five layers are, Kstedfrom bot- 
tom to top: the physical layer (Layer 1), the link layer io y 
(Layer 2), the network layer (Layer 3), the transport layer 
(Layer 4), and the application layer (Layer 5). Ail the 
nodes of the Internet data network contain at Feast the r 
first three layers. Of these nodes, routers, which are pi'\- 
marily responsible forthe couplings \o\ the datanetwork, 
dp not need the transport and application layers. How- ' 
ever, hosts, between which the actual data tr^smissibn 
*' connection is set up, contain all the said five layers. The * 
appended Fig. 4 presents by means of the TCP/IP pro- 
tocol stack the coupling of and communication between *" 20 
two such hosts A, BVia a router R. Even though* all the 
upper level layers use the services of the underlying lay- 
er for data transmission, logically the corresponding lay- 
ers of the hosts A, B communicate with each other by 
using the protocol typical for the layer. The arrows in trie 2$ 
appended Fig. 4 illustrate this communication at the lay- 
er level. ■ * ' " . T " 
[0019] T^eTCP/IPprd^lscanbeusedih a vari^ 
of network solutions, such as the packet switched Ether- 
net and in the Token ring network, or in a switched net-" 30 
work, such as ATM and ISDN. In a connection according 
to Fig. 4, the data transmission between the first host A 
and the router R is conducted in a wireless manner. Data 
transmission between the router R and the second host 
B is conducted by means of a landline Ethernet network, 3$ 
but 4t is obvious that these network solution's only act as" 
examples here. The Institute of Electrical and Electron- 
ics Engineers IEEE has developed a standard 802.11 
for wireless local area networks. In the connection of ' - 
Fig. 4, data transmission according to this standard - *o 
802. 1 1 is used between the host device A and the router 

'r. ' v ; 

[0020] In the following, me meaning of these different 
protocol stack layers will be described briefly. The actual 

; data transmission is conducted in the physical layer by 45 
using a data transmission means, such as a wireless 

. radio network or landline cabling. 
[0021] ' The link layer attends to solutions required by 
different network technologies, wherein the upper level 
layers do not have to know how the data" transmission so 
network used at a given time is constructed. The link 
layer processes different addressing and frame modes 
and is responsible for the data transmission between 

. two terminals in the same communication network. 
[0022] The task of the network layer is to route pack- 55 
eXs between terminals in the' communication network. 
The network layer provides the coupling between differ- 
ent data networks, wherein the upper level layers do not 



have to know about the structure of the data network. 
On this network layer level, for instance protocols IP (In- 
ternet Protocol), ICMP (Internet Control Message Pro- 
tocol) and IGMP (Internet Group Management Protocol) 
are used. 

[0023] The transport layer provides a generic end-to- 
end data transmission connection for the application 
layer. The application layer uses for instance a TCP pro- 
tocol (Transmission Control Protocol) and a UDP proto- 
col (User Datagram Protocol). In the example of Fig. 4, 
the terminals A, B communicate with each other in the 
transport layer by using packets according to the TCP 
protocol. 

[0024] - The application layer protocols operate above 
the transport layer and provide application-specific serv- 
ices, such as Mte transfer services or local area network 
remote login services.lhthe example of Fig. 4, the hosts 
A, B use a so-called HTTP protocol (HyperText Transfer 
Protocol) which is generally used in the Internet data 
network for loading and presenting the data contained 
in so-called home pages in the display device of a com- 
puter. For this purpose, in the example of Fig. 4, the first 
host A is running a so-called web browser program, 
which transmits a request to the Internet web server of 
the second host B. This Internet. web server replies to 
the request by sending the contents of the requested 
home page in HTTP messages". This home page is com- 
posed, for example, by means of hypertext mark-up lan- 
guage HTML. Other application layer protocols include 
Telnet, the file transfer protocol FTP and the simple mail 
transfer protocol SMTP. ^ 
[0025] In the Internet data network, each terminal or 
hosf has its own identifying IP address. The IP address 
is in the Internet protocol version IPv4 a 32 bit, i.e. 4 byte 
number which is split into an organization-specific net- 
work address and a network-specific device address. In 
a newer Internet protocol version- IPv6, the length of the 
address fields is increased to 128 bits, which, in prac- 
tice, means that it is possible to allocate an individual 
address for all the devices which are connected to the 
" Internet data network. An Internet host connected to the 
Internet 'data network via a local area network LAN, 
WLAN has either a permanently specified Internet ad- 
dress or the address is a dynamic address established 
by the local area network server (for example by using 
dynamic host configuration protocol DHCP). If the Inter- 
net host is connected to a telecommunication network 
via a modem, the host has to request for an Internet ad- 
dress from the Internet service provider, to which the In- 
ternet host is registered. This is conducted, for example, 
according to a point-to-point protocol PPP. In both cas- 
es, the data is routed in the Internet to the Internet host 
from a remote terminal, possibly via several communi- 
cation networks and routers by using the specified In- 
ternet address. 

[0026] The Internet protocol IP specifies the data 
transmission in packets ("Datagrams'). When a host or 
- a router receives a packet on the IP level, either from 
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the data network or from an upper level of the protocol 
stack, the first step is to examine whether the packet is 
intended precisely for the router or terminal in question. 
If the packet is intended precisely for this router or ter- 
minal, the packet is transferred from the network layer 
to the upper layer i;i this node. If the packet is intended 
to another node, a so-called routing algorithm is execut- 
ed in the network layer for concluding how the packet 
should be processed. First, it is examined whether the 
packet is intended fcr another node in the same net- 
work. If this is the case, the node can transmit the packet 
ta the destination address by using the mechanisms of 
the link layer. Thus, the IP address of the network layer 
levol is connected to the corresponding link layer ad- 
dress by using the so-called address resolution protocol . 
ARP, which will be described below in this description.. 
In this node, the packet is also framed into a packet cor- . 
responding to the link layer and transmitted further. 
[0027] If the packet is intended for another network,, 
the routing.algorithm runs through a routing table in or- , 
der to find oirt to which address the packet should !?e 
transmitted. The routing table typically contains a so- 
cai'ed default address, to which all such packets are,, 
transmitted whose routing address cannot be found in 
the routing table. • : 

~ The- situation of Fig. 4 can be used as an ex- 
ample of the above described rowing, in which the-first . 
host A and the second host B communicate with each 
other via the router R. In the situation where the first host 
A has a packet to transmit to tha second host B„ the rout- 
ing algorithm detects that the dsstination address of the . 
packet is not located in the sane network-as the first 
hest- A. Thus, , the routing algorithm starts running 
through the routing table and finds the data of the correct 
router R. Thus, the first host A transmits the packet to 
the router by using, for example, data transmission ac- 
cording.to the IEEE 802.11 standard. The router R re- 
ceives the frame, unpacks its content and examines 
from it the header according to the network layer packet 
The router is located in the same network as the second 
host B, wherein the router R c^n transmit the packet di- 
rectly to the second host B by using Ethernet data trans- 
mission, - a . 
[0029] The transmission of I P packets between differ- 
ent coupled data networks on the network layer level is 
conducted on the basis of IP addresses. In addition to 
the IP addresses, the devices connected to the Internet 
data network also have a so-called link layer address, , 
which is also called a devico address. Because termi- 
nals use link layer services in packet transmission with 
terminals connected to the same data network, the ter- 
minals need the address resolution protocol ARP. for 
connecting the !P addresses to the corresponding link 
layer addresses. The reverse address resolution proto- 
col RARP connects the link layer addresses to the cor- 
responding IP addrosses. The. function of the address 
■resolution protocol ARP depends on the structure of the 
data transmission connection used at a given time. For 



example, the serial line Internet protocol SLIP intended 
for series connection, and the point-to-point protocol 
PPP do not require the address resolution protocol ARP 
at all, because the series connection only contains two 

5 well known end points. 

[0030] In such link layer level protocols which make a 
simultaneous connection possible between several dif- 
ferent terminals, i.e. so-called "Broadcast" connections, 
such as the Ethernet,, the address resolution program 

w typically uses four different messages: an ARP request, 
an ARP reply, an RARP request, and an RARP reply. 
Fig. 5 presents the strucure of one such message. The 
first field, hard type, specifies the addressing mode of 
the application layer level. The next field, prot type, kJen- 

T5 titles the type of the network layer level, wherein the ad- 
dress resolution protocol can be used also in network 
. . . layer, level protocols other than I P. A hard size field spec- 
ifies the. length of the link layer address field in the frame, 
and a prot size field specifies the length of the network 

20 layer level address field in the frame. The OP field spec- 
ifies the type, of the message: ah ARP request, an ARP 
reply, an RARP request, or an RARP reply. After this, 
, the frame contains the link layer address field of the 
sender, the link layer address field of the receiver and 

25 the network layer address field of the receiver. 

. . [0031] A terminal can define the physical, i.e. link lay- 
er address of another terminal by transmitting an ARP 
request message, in which the transmitting terminal has 
filled all the other address fields except the link layer 

30 address field of the receiver! At the stage when the re- 
ceiving terminal notices that its link layer address is 
asked for, it replies by transmitting to the source terminal 
an ARP replymessage, in which the address of this link 
layer is transmitted to the inquiring terminal. 

35 [0032] the terminals rhaintain a so-called ARP table 
(ARP cache) which contains the network layer address 
(IP address) and the corresponding link layer address 
of those terminals from which the terminal in question 
has determined this correspondence between address- 
es es. the terminal updates this ARP table at the stage 
, when it receives an ARP reply message to the ARP que- 
ry message, or in the situation when the terminal re- 
ceives an ARP query message transmitted by another 
r terminal, in which the terminal transmitting the message 

4$ has located its own network layer address and its cor- 
responding link layer address. 
[0033] In the IP protocol used by the Internet data net- 
work, a so-called mobile IP protocol has been devel- 
oped to allow the mobility of the terminal. This mobile IP 

. 50 protocol makes it possible for the terminal to move from 
one location to another in the Internet data network, 
maintaining, however, the same IP address. This mobil- 
ity is implemented in the network layer level, wherein 
the change of location does not affect the applications 

55 and the applications can still function even though the 
location changes. This mobility is possible by using a 
so-cailed home agent, which is located in the home net- 
work of a mobile Internet terminal, and which conducts 



BNSDOCID: <EP 0998094 A2J_> 



6 



11 



EP 0 998 094 A2 



12 



re-routing of the messages transmitted to the mobile ter- 
minal to the Internet data network in which the mobile 
terminal is located at a given time. When using solutions 
currently known, however, the mobility requires that the 
connection is maintained by means of a data network of 
a similar type, for example by using a GSM mobile com- 
munication network, if its undesirable to terminate the 
connection. 

[0034] The appended Fig. 6 presents the network ar- 
chitecture of a system in which it is advantageous to ap- 
ply the invention. A terminal A according to the invention 
can be connected for example to a wireless local area 
network WLAN or to a GSM mobile communication net- 
work MNW. The wireless local area network WLAN can 
consist of one or more cells, wherein each ceil contains : 
" a WLAN access point 3, via which the terminal A^can 
' communicate with the localWea network WLAN. In the 
^system of Fig. 6, the WU& actess point 3 is in data' 
. transmission connection via a router R to an IP data net- 
work NW1 , such as the Iritemetdata network. There are 5 v 
also other data networks NW2, NW3 connected to this 
IP data network NWt'via routers R2, R3. 'In the system 
of Fig. 6, a connection is' set up afeo f rom'the GSM mo- 
bile communication network MNW to the IP data 7 net- ; 
work via a gateway GW, which Is known as such. Thus, 
with the terminal A, a data transmission connection can 
be set up also via the GSlyi imbbtle commuriidatioh net- 
' wprkMNVyjothelpM^ * ' J ! - 

(b03Slf' intfiS system of Fig?6, it is presumed thrft"the c 
so-called home network of the terminal A is a second' 
data network NW2, in which a home agent HA is respon- 
„ sible for the mobility management of the terminal WherP 
r the terminal A is not connected to the hdme : network 
NW2. Each data network may further contain foreign r 
agents, through which it is possible to connect the Ter- 
minal A" to communicate in a data network other than ' 
the home'network! ' 

[0036] Fig. 7 presents in a reduced manner the func- 
tionality of the terrhinai A according to an advantageous 
embodiment ^ the invention; The terminal A comprises 
an Ethernet NIC driver D1 1 a wireless local area network 
NIC driver D2 and an NIC driver D3 for connecting to 
the mobile communication network MNW for data trans- 
mission. The>e NIC drivers D1 D2, D3 are device driv- • 
ers known as such, and they comprise an interface for 
connecting to the operating system. These NIC drivers 
D1 , [J2, D3 are usually supplied with the corresponding 
network interface card NIC. The terminal A according to 
the invention is supplemented with a network interface 
selection driver NISD, in which corresponding interfaces 
are established for connecting to the NIC drivers 01 , D2, 
D3. f he network interface selection driver NISD com- 
prises an upper level interface/by means of which it can* 
be connected to the protocol driver PD for transmitting 
information between the protocol driver PD and the net- 
work interface selection driver NISD. This interface is 
an interface known as such: The network interface se- 
lection driver NISD is established between the protocol 
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driver PD of prior art and the NIC drivers D1, D2, D3 
without changes being required in these existing layers. 
The protocol driver PD is, for example, a TCP/IP type 
driver implementing the TCP/IP protocol stack, which is 
implemented for instance in the Windows NT operating 
system software. Data transmission between the proto- 
col driver PD and the network interface selection driver 
Nl SD is conducted preferably by using always the same 
protocol, irrespectively of the type of the data network 
to which the terminal A is connected at a given time. The 
network interface selection driver NISD attends to the 
protocol and 'address modifications required between 
the protocol driver PD and the NIC drivers D1, D2, D3. 
The diagram of Fig. 7 also shows a management appli- 
cation MA for the network interface selection driver, for 
controlling e.g. the function of the network interface se- 
lection driver NISD and the selection of the NIC driver 
D1 ,'■ D2, D3 corresponding to the network interface used 
at a given time.- 

[0037] In the following, the function of a terminal A ac- 
cording to an advantageous-embodiment of the inven- 
tion will be described with an example. When the termi- 
- nal A is set to work, the operating system loads the NIC 
drivers D1 , D2, D3, the intermediate drivers and the pro- 
tocol drivers in the tecminal memory MEM. By means of 
system settings, it is possibleiocontrolthe loading order 
,; ahd the drivers to be loaded;* An I/O manager in the op- 
" crating system also starts the operation of the network 
interface selection driver.NiSD. The network interface 
selection driver NISD determines from the started NIC 
drivers D1; D2, -D3, for instance their features and the 
connection state/of each NIC driver, in other words 
whether the network-interface card corresponding to the 
NIC driver D1, D2; D3 is connected to the data trans- 
mission network. Before starting the management ap- 
plication MA of the network interface selection driver, 
i " the network interface selection driver NISD transmits to 
the protocol driver PD the information that the terminal 
' A is hot yet connected to any data network . 
[0038] After it is started, the management application 
MA of the network interface selection driver examines 
' which NIC drivers D1 , 02, D3 are started in the terminal 
A and what is the quality of each active connection. It is 
' 1 also possible that a network interface card has received 
from the corresponding data network an advertisement 
message from an agent, such as an home agent or a 
foreign agent, by means of which the agent aims at de- 
fining the address information of the terminals A con- 
nected to the data network. On the basis of the defined 
information;-the;management application MA of the net- 
work interface selection driver directs the network inter- 
face selection driver NISD to transmit, when necessary, 
* a registration message to that data network NW1 , NW2, 
NW3, MNW, to which the network interface selection 
driver 'management application MA or the user of the 
terminal A desires to be connected at that moment. At 
this stage -the. network interface selection driver NISD 
indicates to the protoco? driver PD that the coupling to 
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the data network is activated, wherein the network in- 
terface selection driver NISD can start transmitting - 
packets. 

[0039] Fig. 8a presents, in an arrow diagram, data 
transmission from the terminal A to the activated data 
network NW1, NW2, NW3 ( MNW. From the data to be 
transmitted, which is for example a message composed 
by a browser application, for sxample packets according 
to the IP protocol are formed in the protocol driver PD. 
These packets are transferred to the network interface 
selection driver NISD (arrow 701) via an tipper level 
NDIS interface 702, which in practical applications can 
be implemented for example as a function call to a sub- 
program within the network interface selection driver 
NISD, which is obvious for anyone skilled in the art. This 
is shown by the arrow 703 in Fig. 8a. The network inter- 
face selection driver NISD returns state information 
STATU S_PENDI NG to the protocol driver PD (arrows 
704, 705), on the basis of which the protocol driver PD 
knows that the message is waiting for transmission . The 
network interface selection driver NISD forms the pack- * 
et into a packet according to the data network which is " 
active at that moment and to which the packet is trans- 
mitted: The network interface selection driver NISD 
transmits the packet it has formed via lower level NDIS 
interface 706 to the NIC driver D1 , 02, D3 of the active 
data network (arrows 707; 70S). After receiving the 
packet, the NIC driver D1, D2,' D3 transmits staid infor- 
mation STATUS_PENDING to the network interface se- 
lection driver NISD (arrows 709, 710) and transmits the 
packet to the network interface card, in which the actual 
data transmission to the data network is conducted In a 
way known as such. After the packet has been transmit- 
ted to the data network; the NIC driver D1 , D2, D3 trans- 
mits state information HEADY to the network interface 
selection driver NISD (arrows 711 , 712), from which the 
state information is transmitted further to the protocol 
driver PD (arrows 71 3, 714). The aforementioned pack- 
et transfer between the protocol driver PD, the network- 
interface selection driver NISD and the NIC driver D1, 
D2, D3 does not necessarily require copying the 1 con- 
tents of the packet always to a new location in the' ter- 
minal memory MEM, but forexample a memory address 
in which the packet is located can be transmitted, 
[0040] Fig. 8b, correspondingly, presents packet re- 
ception from the data network. After the network inter- 
face card of the active data network has rece.ved the 
packet and transmitted it to the corresponding NIC driv- 
er D1, D2, D3, the NIC driver 01, D2, D3 transmits in- 
formation on the received packet via the lower level 
NDIS interface 706 to the network interface selection 
driver NiSD (arrows 715, 71 o). In the network interface 
selection driver NISD, a function call or the like is con- 
ducted, whereby the* NIC driver D1, D2, D3 which has 
received the packet is directed to transfer the packet to 
the network interface selection driver NISD (arrows 717,. 
718). ThetilCdriverDi; D2, D3 can, at this stage, trans- 
mit state inforrriati^^^ to the network 



interface selection driver NISD (arrows 719, 720) in or- 
der to report that transmission is being started. During 
the transmission, the network interface selection driver 
NISD can conduct other functions if necessary. When 

5 the packet transmission is finished, the NIC driver D1, 
D2, D3 reports this to the network interface selection 
driver NISD (arrows 721 , 722), after which the network 
interface selection driver NISD can examine the con- 
tents of the packet and decide what procedures the 

10 packet entails. In the example of Fig. 8b, the network 
interface selection driver NISD transmits the packet to 
the protocol driver PD (arrows 723, 724), in which the 
processing of the data of the packet is conducted in a 
way known as such. This processing is illustrated in 

*5 block 725 of Fig. 8b. After this; the protocol driver PD 
also indicates (arrows 726, 727) that it has processed 
the packet and is ready to receive a new packet. 
[0041] The protocol driver PD of the terminal A is not 
aware that there are more than one network interface 

20 cards available in the terminal A. Thus, the protocol driv- 
er PD uses the same address information irrespective 
of the data network to which information is being trans- 
mitted at a given time. .Therefore, an address resolution 
protocol ARP is established in the network interface se- 

25 lection driver NISD, by means of which the address 
modifications are conducted when necessary. In the fol- 
lowing, this will be illustrated with some examples. 
[0042] . In a first situation, it is presumed that the user 
usesthe terminal A^sccnewhere else than in the home 

30 network NW2 of the terminal A. and that the terminal A 
~ does not use said foreign agents in the data transmis- 
sion. The address resolution protocol is implemented in 
the network interface selection driver NISD. The proto- 
col driver PD implemented in the operating system can, 

3S however, transmit ARP messages which are not being 
transmitted from the terminal A forward, but to which the 
network interface selection driver NISD replies with ran- 
dom information. . 

[0043] The address resolution protocol of the network 

40 interface selection driver NISD examines the link layer 
addresses of those terminals, which are coupled to the 
same data network with the terminal A at that moment. 
This can be implemented by sending from the terminal 
. A ARP query messages, to which other terminals reply. 

45 These ARP messages have been briefly described 
above in, this description. After receiving an ARP reply 
- message, the address resolution protocol can update 
the ARP table in which the correspondence between the 
link layer address of the terminal and the corresponding 

so network layer address becomes evident. The terminal 
A can also receive ARP query messages, in which an- 
other terminal inquires the address of this terminal A in 
* this data network. For example, the term care-of -ad- 
dress can be used for this address. 

55 [0044]^ In another situation, the user uses the terminal 
A somewhere else than in ,ths home network NW2 of 
the terminal A and the terminal A uses said foreign 
agents in the data transmission. Thus, the network in- 
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terface selection driver NISD does not have to conduct 
the address resolution protocol, because it receives the 
link layenaddress of the foreign agent in the advertise- 
ment messages transmitted by the foreign agent and re- 
ceived by the terminal A. Also in this case, the network 
interface selection driver NISD replies with random in- 
formation to the ARR messages transmitted by the pro- .. 
tocol driver PD. 

[0045] In a situation where the user uses the terminal 
A in the home network NW2, the terminal A could use 
the address resolution protocol of the protocol driver PDr 
this, however, causes problems in solutions of prior art 
when the terminal A is transferred to use another data - 
network, because, for instance, in the address resolu-- 
tion protocol of the protocol driver PD of Windows NT, : 
this possibility to change, the data network is not taken , 
into account. Thus, the protocol driver PD would contin- 
ued transmit packets to an address according tp ther v 
link layer of a terminal in the home network NW2. This. . . 
1 however, does not mean the same terminal in that .data ; 
network, which the terminal A has entered, and packet- 1 
transmission is not successful. In this method and ter- . 
minal A according to an advantageous embodiment of . 
the invention, the address resolution protocol estab- 
lished- in the network interface selection driver NISD as - 
well as its own ARP table aire used also when the ter : ; 
minal A is connected to the.home network. Injthapapk- ; 
ets which are being transmitted,, the network interface 
selection driver NISD changes the destination address: 
* set by the protocol driver PD into a link layer address f - 
r which can be accessed from the ARP table on the basis 
of network layer address information. The network in- 
terface selection driver NISD can also reply, for example . 
with random messages, to inquiries possibly transmitted 
by the address resolution protocol of the protocol driver 
PD. - 

[0046] Next, we shall discuss a situation .where the 
terminal A shifts an active connection from one data net- 
work to another. The reason for the connection transition * 
can be that the terminal A is transfer red outside the serv- 
ice area of an active data network, or for another reason 
the connection quality in the active data network deteri- 
orates at that moment to such an extent that the network 
interface selection driver NISD starts to change the con- 
nection to another data network. A reason for the con- 
nection change can also be that the terminal A enters, 
the operation range of such a data network which the 
user has given a higher priority than the data network 
active at the moment. The terminal A is, for example,: 
connected to a GSM mobile communication network 
and the user of the terminal arrives in an office whema 
wireless local area netwok is available. The appended. 
Fig. 8c shows this data transmission network change in 
a reduced arrow diagram. It is presumed that the termi- 
nal A is connected to a second terminal 3 via a GSM. 
mobile communication network. The connection is for 
example a TCP connection. The terminal A transmits IP 
packets to the second terminal B directly, v/ithout tun- 



neling, via a server 728 located in the GSM mobile com- 
munication network. This is illustrated with arrows 729 
and 730. The second terminal B transmits IP packets to 
. the first terminal A via the home agent HA of the first 
s terminal (arrow 731 ), from which the packets are trans- 
mitted via the server 728 to the first terminal A (arrows 
732 and 733). In the first terminal A, the network inter- 
face selection driver NISD chooses to shift the connec- 
tion to another data network, in this example to the wire- 
10 less local area network WLAN (block 734). The first ter- 
minal A transmits a registration request message to the 
home agent HA via the wireless local area network 
WLAN (arrows 735 and. 736) and at the same time con- 
tinues totransmit IP packets via the GSM mobile com- 
1.5 munication network, if there ar9 packets to be transmit- 
ted and the connection quality inadequate. The home 
agent HA receives the registration request, updates the 
: new location address of the first terminal A in its own 
database and transmits a registration reply message via 
20 - the wireless local area nelwqrkWLAN to the first termi- 
nal A (arrows 737, 738). After this, the home agent HA 
transmits the packets. addressed to the first terminal A 
- to the wireless local area network WLAN , instead of the 
. ... GSM mobile corrimurycation. network. After receiving 
2S the registration, reply message, the first terminal A ter- 
minates the connection tojrjaGSM mobile communica- 
tion netwonVand starts | to^nsmit packets by using the 
wireless local area network. Irt Jhe above described 
method accordingio an-adyantageous embodiment of 
30 the invention, it is not necessary for the second terminal 
B and its applications to knowthe.data network and ad- 
dress used by-the first terminal A in this data network at 
a given time, the applications of the second terminal B 
can still trapsmit by using the same IP address of the 
as first terminal. b 

[0047] As a summary on the function of the network 
interface selection driver NISD, it is mentioned that its 
purpose is to route. the TCP/lP packets from the protocol 
driver PD to the NIC driver Di . Q2, D3, which the man- 
. 40 agement application MA of the network interface selec- 
tor driverhas selected to be active, and correspondingly 
to transmit.the packets receive^ by the NIC driver D1, 
D2. D3 to the protocol driver PD and to make the nec- 
essary modifications in for the packets being transmitted 
45 and .received, in addition, the network interface selec- 
tion driver NISD comprises IP protocol mobility manage- 

- ment functions, (mobile IP), such as tunneling of pack- 
ets, transmission and reception of registration messag- 

- es, transmission and reception of foreign agent resolu- 
so tion messages and reception of advertisement messag- 
es transmitted by foreign agents. 

[0048] With the management application MA of the 
network interface selection driver, the user can control 
the f unctional alignments of the network interfaces of the 
55 terminal A, such as quality parameters, on the basis of 

- which the^management application MA of the network 
interface selection driver examines, for instance, wheth- 

• er the quality oUhe connection is adequate in the data 
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network used at that moment, or should a connection to 
another data network available be attempted. The user 
can also determine the priority among data networks, 
wherein the data network with the highest priority is ad- 
vantageously selected from the data networks with ad- 
equate connection quality. The management applica- 
tion MA of the network interface selection driver is also 
responsible for directing the connection set-up and cut 
off to the mobile communication network MNW when 
necessary. 

[0049] The invention is not restricted solely to the em- 
bodiments presented above, but it can be modified with- 
in the scope of the appended claims. 



Claims 

1 . A terminal (A) which comprises at least one network 
interface (NIC1 , IMIC2, N1C3) for setting jjp. -a data 
transmission connection to a communication; net- 
work (NW1 , NW2, NW3, MNW) for packet switched 
data transmission, means (PD) for forming packets 
of the information to be transmitted and for unpack- 
ing information from received packets, character- 
ized in that :t '_.:*.£/. 

the terminal (A) is arranged to allocate at least 
one first address identifying the terminal. (A) , 
and at teast one data network-specific second, 
address, 

the means (PD) for forming packets comprisa 
means for connecting the first arWresc to the 
packets, and 

the terminal (A) also comprises a network inter- 
face selection driver (NtSD), which includes 
means for selecting the communication net- 
work (NWt. NW2, NW3, MNW) used in data 
transmission at a given time, means for trans- 
mitting packets between the means (PD) for 
forming packets and the network interface card 
(NIC1, NIC2, NIC3) corresponding to the data 
transmission network (NW1, NW2, NW3, 
MNW) used at a given time, and means for con- 
verting the first address into a second address 
according to the data transmission network 
used in the packets at a given time. 

2. The terminal (A) according to claim 1 , characterized 
in that the network interface selection driver (NISD) 
is established between the means (PD) for forming 
packets and the network interface card (NIC1, 
NIC2, NIC3) without making modifications to the 
means (PD) for forming packets and to the network 
interface card (NIC1, NIC2, NIC3). 

3. The terminal (A) according to claim 1 or 2, charac- 
terized in that the network interface selection driver 
(NISD) is provided with the address resolution pro- 
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tocol (ARP) for modifying the first address into the 
second address according to the data network used 
in the packets at a given time. 

5 4. The terminal (A) according to claim 1 , 2 or 3, char- 
acterized in that the address modification is ar- 
ranged ?o be conducted without terminating the da- 
ta transmission connection. 

ic 5. The terminal (A) according to any of the claims 1 to 
4, characterized in that it comprises means (NISD, 
D1, D2, D3, NIC1, N1C2, NIC3) for changing the 
communication network (NW1 , NW2, NW3, MNW) 
r used in the data transmission connection at a given 
*5 Jr v time without terminating the data transmission con- 
f . nection. 

Thei9rminal (A) according to any of the claims 1 to 
:n 5, characterized in that it comprises means (D1.D2, 
■J^.wv. P 3 ) tor controlling.. the. network interface cards 
(NJC1, NIC2, NIC3). 

7. The terminal (A) according to any of the claims 1 to 
•„. 6, characterized in that the network interface selec- 
ts tion driver (NISD) comprises IP protocol mobility 

, ■ , management functions (Mobile IP), such as packet 
.^tunneling,, transmission and reception of registra- 
< > tiorvmessages, transmission of foreign agent reso- 
rt lutton f messages ti and, reception of advertisement 

39 . messages transmitted by foreign agents. 

8. A method of packet switched data transmission be- 
tween a terminal (A) and a communication network 
(NW1, NW2, NW3, MNW), in which method data 

35 transmission connection to the data transmission 
network (NW1, NW2, NW3, MNW) is set up with a 
network interface card (NIC1, NIC2. NIC3) of the 
terminal (A), and packets are formed of the informa- 
tion to be transmitted, and information transmitted, 

40 characterized in that in the method 

- the terminal (A) is allocated at least one ad- 
dress identifying the terminal (A) and at least 
one data network-specific second address, 

4$ - the first address is connected to the packets 
and the first address is modified to a second 
address according to the data transmission net- 
work used in the packets at a given time, 
the data transmission network to be used at a 

so given time is selected, wherein packets are 

transmitted via a network interface card (NIC1 , 
NIC2, NIC3) corresponding to the data trans- 
mission network (NW1, NW2, NW3, MNW) 
used at a given time. 

55 

9. The method according to claim 8, characterized in 
that in order to modify the first address to the second 
address according to the data transmission network 
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used in the packets at a given time, the address res- 
olution protocol (ARP) is used. 

10. The method according to claim 8 or 9, characterized 

in that the terminal is allocated one data transmis- s 
sion network (NW1 . NW2, NW3, MNW) as a home 
network for said terminal (A), and said home net- 
work is provided with a home agent (HA) for direct- 
ing packets addressedto the terminal (A)tothedata 
network used by said terminal (A) in a data trans- 10 
mission connection. 

11. The method according to claim 8, 9 or 10, charac- 
terize! in that in the method, the quality of the data 
transmission connection used at a given time is « 
monitored, and if the quality deteriorates below a 
specified limit, it is examined whether a better con- 

; - nectibn quality-can be^achieved with another data- 

transmission network available, wherein the data 
tranmission cohnecticHi'is changed to such a data 20 . 
transmission network with which a better connec- " 
tion quality is achieved. , . ; . - 

1 2i The method accordin g to any of the claims 8 to 11 , 
characterized in that to change the data transmis- 2s 
sion connection from said data network to another 
' data network, a first message is transmitted from * - 
the termihat (A) J to this home agent (HA); which 
transmits an acfcnowlegment message of the 
change of the data network to the terminal (A), and so 
information on the data network used in the data 
transmission connection at a given time is stored in • 
the home agent (HA). 

- 3$ 
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